<template>
    <div class="app-container">
        <el-form
            :model="queryParams"
            ref="queryForm"
            size="small"
            :inline="true"
            v-show="showSearch"
            label-width="68px"
        >
            <el-form-item label="岗位" prop="postId">
                <el-select
                    v-model="queryParams.postId"
                    placeholder="请选择岗位"
                    clearable
                >
                    <el-option
                        v-for="d in postList"
                        :key="d.postId"
                        :label="d.postName"
                        :value="d.postId"
                    />
                </el-select>
            </el-form-item>
            <el-form-item label="姓名" prop="name">
                <el-input
                    v-model="queryParams.name"
                    placeholder="请输入姓名"
                    clearable
                    @keyup.enter.native="handleQuery"
                />
            </el-form-item>
            <el-form-item label="性别" prop="sex">
                <el-select
                    v-model="queryParams.sex"
                    placeholder="请选择性别"
                    clearable
                >
                    <el-option
                        v-for="dict in dict.type.sys_user_sex"
                        :key="dict.value"
                        :label="dict.label"
                        :value="dict.value"
                    />
                </el-select>
            </el-form-item>
            <el-form-item label="教育经历" prop="education">
                <el-select
                    v-model="queryParams.education"
                    placeholder="请选择教育经历"
                >
                    <el-option
                        v-for="dict in dict.type.education_list"
                        :key="dict.value"
                        :label="dict.label"
                        :value="dict.value"
                    ></el-option>
                </el-select>
            </el-form-item>
            <el-form-item label="毕业学校" prop="school">
                <el-input
                    v-model="queryParams.school"
                    placeholder="请输入毕业学校"
                    clearable
                    @keyup.enter.native="handleQuery"
                />
            </el-form-item>
            <el-form-item label="简历级别" prop="level">
                <el-select
                    v-model="queryParams.level"
                    placeholder="请选择简历级别"
                    clearable
                >
                    <el-option
                        v-for="dict in dict.type.hrm_resume_level"
                        :key="dict.value"
                        :label="dict.label"
                        :value="dict.value"
                    />
                </el-select>
            </el-form-item>
            <el-form-item label="是否通面" prop="ifNotice">
                <el-select
                    v-model="queryParams.ifNotice"
                    placeholder="请选择是否通知面试"
                    clearable
                >
                    <el-option
                        v-for="dict in dict.type.sys_yes_no"
                        :key="dict.value"
                        :label="dict.label"
                        :value="dict.value"
                    />
                </el-select>
            </el-form-item>
            <el-form-item label="是否参面" prop="ifInterview">
                <el-select
                    v-model="queryParams.ifInterview"
                    placeholder="请选择是否参加面试"
                    clearable
                >
                    <el-option
                        v-for="dict in dict.type.sys_yes_no"
                        :key="dict.value"
                        :label="dict.label"
                        :value="dict.value"
                    />
                </el-select>
            </el-form-item>
            <el-form-item label="是否录用" prop="ifPass">
                <el-select
                    v-model="queryParams.ifPass"
                    placeholder="请选择是否录用"
                    clearable
                >
                    <el-option
                        v-for="dict in dict.type.sys_yes_no"
                        :key="dict.value"
                        :label="dict.label"
                        :value="dict.value"
                    />
                </el-select>
            </el-form-item>
            <el-form-item label="是否内推" prop="ifRecommend">
                <el-select
                    v-model="queryParams.ifRecommend"
                    placeholder="请选择是否内部推荐"
                    clearable
                >
                    <el-option
                        v-for="dict in dict.type.sys_yes_no"
                        :key="dict.value"
                        :label="dict.label"
                        :value="dict.value"
                    />
                </el-select>
            </el-form-item>
            <el-form-item>
                <el-button
                    type="primary"
                    icon="el-icon-search"
                    size="mini"
                    @click="handleQuery"
                    >查询</el-button
                >
                <el-button
                    icon="el-icon-refresh"
                    size="mini"
                    @click="resetQuery"
                    >重置</el-button
                >
            </el-form-item>
        </el-form>

        <TableCard>
            <el-row :gutter="10" class="mb8">
                <el-col :span="1.5">
                    <el-button
                        type="primary"
                        plain
                        icon="el-icon-plus"
                        size="mini"
                        @click="handleAdd"
                        v-hasPermi="['hrm:resume:add']"
                    >
                        新增
                    </el-button>
                </el-col>
                <el-col :span="1.5">
                    <el-button
                        type="success"
                        plain
                        icon="el-icon-edit"
                        size="mini"
                        :disabled="single"
                        @click="handleUpdate"
                        v-hasPermi="['hrm:resume:edit']"
                    >
                        修改
                    </el-button>
                </el-col>
                <el-col :span="1.5">
                    <el-button
                        type="danger"
                        plain
                        icon="el-icon-delete"
                        size="mini"
                        :disabled="multiple"
                        @click="handleDelete"
                        v-hasPermi="['hrm:resume:remove']"
                    >
                        删除
                    </el-button>
                </el-col>
                <el-col :span="1.5">
                    <el-button
                        type="warning"
                        plain
                        icon="el-icon-download"
                        size="mini"
                        @click="handleExport"
                        v-hasPermi="['hrm:resume:export']"
                    >
                        导出
                    </el-button>
                </el-col>
                <right-toolbar
                    :showSearch.sync="showSearch"
                    @queryTable="getList"
                ></right-toolbar>
            </el-row>

            <el-table
                :border="Global.tableShowBorder"
                v-loading="loading"
                :data="resumeList"
                @selection-change="handleSelectionChange"
            >
                <el-table-column type="selection" width="55" align="center" />
                <el-table-column
                    label="简历文件"
                    align="center"
                    prop="resumeUrl"
                    width="150"
                >
                    <template slot-scope="scope">
                        <el-link
                            :href="baseUrl + scope.row.resumeUrl"
                            :underline="false"
                            target="_blank"
                        >
                            <img
                                src="@/assets/images/am/filext/DOC.png"
                                style="width: 50px"
                            />
                        </el-link>
                    </template>
                </el-table-column>
                <el-table-column
                    label="姓名"
                    align="center"
                    prop="name"
                    width="180"
                />
                <el-table-column
                    label="性别"
                    align="center"
                    prop="sex"
                    width="120"
                >
                    <template slot-scope="scope">
                        <dict-tag
                            :options="dict.type.sys_user_sex"
                            :value="scope.row.sex"
                        />
                    </template>
                </el-table-column>
                <el-table-column
                    label="教育经历"
                    align="center"
                    prop="education"
                    width="180"
                >
                    <template slot-scope="scope">
                        <dict-tag
                            :options="dict.type.education_list"
                            :value="scope.row.education"
                        />
                    </template>
                </el-table-column>
                <el-table-column
                    label="毕业学校"
                    align="center"
                    prop="school"
                    :show-overflow-tooltip="true"
                    width="300"
                />
                <el-table-column
                    label="参加工作时间"
                    align="center"
                    prop="workTime"
                    width="180"
                >
                    <template slot-scope="scope">
                        <span>{{
                            parseTime(scope.row.workTime, "{y}-{m}-{d}")
                        }}</span>
                    </template>
                </el-table-column>
                <el-table-column
                    label="简历级别"
                    align="center"
                    prop="level"
                    width="180"
                >
                    <template slot-scope="scope">
                        <dict-tag
                            :options="dict.type.hrm_resume_level"
                            :value="scope.row.level"
                        />
                    </template>
                </el-table-column>
                <el-table-column
                    label="是否通知面试"
                    align="center"
                    prop="ifNotice"
                    width="150"
                >
                    <template slot-scope="scope">
                        <dict-tag
                            :options="dict.type.sys_yes_no"
                            :value="scope.row.ifNotice"
                        />
                    </template>
                </el-table-column>
                <el-table-column
                    label="是否参加面试"
                    align="center"
                    prop="ifInterview"
                    width="150"
                >
                    <template slot-scope="scope">
                        <dict-tag
                            :options="dict.type.sys_yes_no"
                            :value="scope.row.ifInterview"
                        />
                    </template>
                </el-table-column>
                <!--                <el-table-column label="面试时间" align="center" prop="interviewTime" width="180">-->
                <!--                    <template slot-scope="scope">-->
                <!--                        <span>{{ parseTime(scope.row.interviewTime, '{y}-{m}-{d}') }}</span>-->
                <!--                    </template>-->
                <!--                </el-table-column>-->
                <el-table-column
                    label="是否录用"
                    align="center"
                    prop="ifPass"
                    width="150"
                >
                    <template slot-scope="scope">
                        <dict-tag
                            :options="dict.type.sys_yes_no"
                            :value="scope.row.ifPass"
                        />
                    </template>
                </el-table-column>
                <el-table-column
                    label="是否内部推荐"
                    align="center"
                    prop="ifRecommend"
                    width="150"
                >
                    <template slot-scope="scope">
                        <dict-tag
                            :options="dict.type.sys_yes_no"
                            :value="scope.row.ifRecommend"
                        />
                    </template>
                </el-table-column>
                <el-table-column
                    label="电话"
                    align="center"
                    prop="phone"
                    width="180"
                ></el-table-column>
                <el-table-column
                    label="邮箱"
                    align="center"
                    prop="email"
                    width="180"
                ></el-table-column>
                <el-table-column
                    label="操作"
                    align="center"
                    class-name="small-padding fixed-width"
                    fixed="right"
                    width="180"
                >
                    <template slot-scope="scope">
                        <el-button
                            size="mini"
                            type="text"
                            icon="el-icon-edit"
                            @click="handleUpdate(scope.row)"
                            v-hasPermi="['hrm:resume:edit']"
                        >
                            修改
                        </el-button>
                        <el-button
                            size="mini"
                            type="text"
                            icon="el-icon-delete"
                            @click="handleDelete(scope.row)"
                            v-hasPermi="['hrm:resume:remove']"
                        >
                            删除
                        </el-button>
                    </template>
                </el-table-column>
            </el-table>

            <pagination
                v-show="total > 0"
                :total="total"
                :page.sync="queryParams.pageNum"
                :limit.sync="queryParams.pageSize"
                @pagination="getList"
            />
        </TableCard>

        <!-- 添加或修改简历档案对话框 -->
        <el-dialog
            :title="title"
            :visible.sync="open"
            width="1000px"
            append-to-body
        >
            <el-form
                ref="form"
                :model="form"
                :rules="rules"
                label-width="120px"
            >
                <el-row
                    style="display: flex; flex-direction: row; align-items: end"
                >
                    <el-col :xs="24" :sm="12" :md="12" :lg="12">
                        <el-form-item label="简历文件地址" prop="resumeUrl">
                            <file-upload v-model="form.resumeUrl" :limit="1" />
                        </el-form-item>
                    </el-col>
                    <el-col :xs="24" :sm="12" :md="12" :lg="12">
                        <el-form-item label="岗位" prop="postId">
                            <el-select
                                v-model="form.postId"
                                placeholder="请选择岗位"
                                clearable
                            >
                                <el-option
                                    v-for="d in postList"
                                    :key="d.postId"
                                    :label="d.postName"
                                    :value="d.postId"
                                />
                            </el-select>
                        </el-form-item>
                    </el-col>
                </el-row>

                <el-col :xs="24" :sm="12" :md="12" :lg="12">
                    <el-form-item label="姓名" prop="name">
                        <el-input
                            v-model="form.name"
                            placeholder="请输入姓名"
                        />
                    </el-form-item>
                </el-col>
                <el-col :xs="24" :sm="12" :md="12" :lg="12">
                    <el-form-item label="性别">
                        <el-radio-group v-model="form.sex">
                            <el-radio
                                v-for="dict in dict.type.sys_user_sex"
                                :key="dict.value"
                                :label="dict.value"
                                >{{ dict.label }}</el-radio
                            >
                        </el-radio-group>
                    </el-form-item>
                </el-col>
                <el-col :xs="24" :sm="12" :md="12" :lg="12">
                    <el-form-item label="教育经历" prop="education">
                        <el-select
                            v-model="form.education"
                            placeholder="请选择是否录用"
                        >
                            <el-option
                                v-for="dict in dict.type.education_list"
                                :key="dict.value"
                                :label="dict.label"
                                :value="dict.value"
                            ></el-option>
                        </el-select>
                    </el-form-item>
                </el-col>
                <el-col :xs="24" :sm="12" :md="12" :lg="12">
                    <el-form-item label="毕业学校" prop="school">
                        <el-input
                            v-model="form.school"
                            placeholder="请输入毕业学校"
                        />
                    </el-form-item>
                </el-col>
                <el-col :xs="24" :sm="12" :md="12" :lg="12">
                    <el-form-item label="简历级别" prop="level">
                        <el-select
                            v-model="form.level"
                            placeholder="请选择简历级别"
                        >
                            <el-option
                                v-for="dict in dict.type.hrm_resume_level"
                                :key="dict.value"
                                :label="dict.label"
                                :value="dict.value"
                            ></el-option>
                        </el-select>
                    </el-form-item>
                </el-col>
                <el-col :xs="24" :sm="12" :md="12" :lg="12">
                    <el-form-item label="参加工作时间" prop="workTime">
                        <el-date-picker
                            clearable
                            v-model="form.workTime"
                            type="date"
                            value-format="yyyy-MM-dd"
                            placeholder="请选择参加工作时间"
                        ></el-date-picker>
                    </el-form-item>
                </el-col>
                <el-col :xs="24" :sm="12" :md="12" :lg="12">
                    <el-form-item label="是否通知面试" prop="ifNotice">
                        <el-select
                            v-model="form.ifNotice"
                            placeholder="请选择是否通知面试"
                        >
                            <el-option
                                v-for="dict in dict.type.sys_yes_no"
                                :key="dict.value"
                                :label="dict.label"
                                :value="dict.value"
                            ></el-option>
                        </el-select>
                    </el-form-item>
                </el-col>
                <el-col :xs="24" :sm="12" :md="12" :lg="12">
                    <el-form-item label="是否参加面试" prop="ifInterview">
                        <el-select
                            v-model="form.ifInterview"
                            placeholder="请选择是否参加面试"
                        >
                            <el-option
                                v-for="dict in dict.type.sys_yes_no"
                                :key="dict.value"
                                :label="dict.label"
                                :value="dict.value"
                            ></el-option>
                        </el-select>
                    </el-form-item>
                </el-col>
                <!--                <el-col :xs="24" :sm="12" :md="12" :lg="12">-->
                <!--                    <el-form-item label="面试时间" prop="interviewTime">-->
                <!--                        <el-date-picker clearable v-model="form.interviewTime" type="date" value-format="yyyy-MM-dd" placeholder="请选择面试时间"></el-date-picker>-->
                <!--                    </el-form-item>-->
                <!--                </el-col>-->
                <el-col :xs="24" :sm="12" :md="12" :lg="12">
                    <el-form-item label="是否录用" prop="ifPass">
                        <el-select
                            v-model="form.ifPass"
                            placeholder="请选择是否录用"
                        >
                            <el-option
                                v-for="dict in dict.type.sys_yes_no"
                                :key="dict.value"
                                :label="dict.label"
                                :value="dict.value"
                            ></el-option>
                        </el-select>
                    </el-form-item>
                </el-col>
                <el-col :xs="24" :sm="12" :md="12" :lg="12">
                    <el-form-item label="是否内部推荐" prop="ifRecommend">
                        <el-select
                            v-model="form.ifPass"
                            placeholder="请选择是否内部推荐"
                        >
                            <el-option
                                v-for="dict in dict.type.sys_yes_no"
                                :key="dict.value"
                                :label="dict.label"
                                :value="dict.value"
                            ></el-option>
                        </el-select>
                    </el-form-item>
                </el-col>

                <el-col :xs="24" :sm="12" :md="12" :lg="12">
                    <el-form-item label="电话" prop="phone">
                        <el-input
                            v-model="form.phone"
                            placeholder="请输入电话"
                        />
                    </el-form-item>
                </el-col>

                <el-col :xs="24" :sm="12" :md="12" :lg="12">
                    <el-form-item label="邮箱" prop="email">
                        <el-input
                            v-model="form.email"
                            placeholder="请输入邮箱"
                        />
                    </el-form-item>
                </el-col>
            </el-form>
            <div slot="footer" class="dialog-footer">
                <el-button type="primary" @click="submitForm">确 定</el-button>
                <el-button @click="cancel">取 消</el-button>
            </div>
        </el-dialog>
    </div>
</template>

<script>
import {
    listResume,
    getResume,
    delResume,
    addResume,
    updateResume,
} from "@/api/hrm/resume";
import { listPostAll } from "@/api/system/post";

export default {
    name: "Resume",
    dicts: ["hrm_resume_level", "sys_yes_no", "sys_user_sex", "education_list"],
    data() {
        return {
            baseUrl: process.env.VUE_APP_BASE_API,
            // 职位选项
            postList: [],
            // 遮罩层
            loading: true,
            // 选中数组
            ids: [],
            // 非单个禁用
            single: true,
            // 非多个禁用
            multiple: true,
            // 显示查询条件
            showSearch: true,
            // 总条数
            total: 0,
            // 简历档案表格数据
            resumeList: [],
            // 弹出层标题
            title: "",
            // 是否显示弹出层
            open: false,
            // 查询参数
            queryParams: {
                pageNum: 1,
                pageSize: 20,
                orderByColumn: "createTime",
                isAsc: "descending",
                postId: null,
                name: null,
                sex: null,
                education: null,
                school: null,
                workTime: null,
                level: null,
                ifNotice: null,
                ifInterview: null,
                interviewTime: null,
                ifPass: null,
                interviewScore: null,
            },
            // 表单参数
            form: {
                ifRecommend: "N",
                ifNotice: "N",
                ifInterview: "N",
                ifPass: "N",
            },
            // 表单校验
            rules: {
                resumeUrl: [
                    {
                        required: true,
                        trigger: "blur",
                        message: "简历文件不能为空",
                    },
                ],
                name: [
                    {
                        required: true,
                        trigger: "blur",
                        message: "姓名不能为空",
                    },
                ],
                postId: [
                    {
                        required: true,
                        trigger: "blur",
                        message: "岗位不能为空",
                    },
                ],
                level: [
                    {
                        required: true,
                        trigger: "blur",
                        message: "简历级别不能为空",
                    },
                ],
            },
        };
    },
    created() {
        this.getList();
        this.getPostList();
    },
    methods: {
        getPostList() {
            listPostAll().then((res) => {
                this.postList = res.data;
            });
        },
        /** 查询简历档案列表 */
        getList() {
            this.loading = true;
            listResume(this.queryParams).then((response) => {
                this.resumeList = response.rows;
                this.total = response.total;
                this.loading = false;
            });
        },
        // 取消按钮
        cancel() {
            this.open = false;
            this.reset();
        },
        // 表单重置
        reset() {
            this.form = {
                id: null,
                postId: null,
                resumeUrl: null,
                name: null,
                sex: "0",
                education: null,
                school: null,
                workTime: null,
                createTime: null,
                level: null,
                interviewTime: null,
                ifRecommend: "N",
                ifNotice: "N",
                ifInterview: "N",
                ifPass: "N",
                interviewScore: null,
            };
            this.resetForm("form");
        },
        /** 查询按钮操作 */
        handleQuery() {
            this.queryParams.pageNum = 1;
            this.getList();
        },
        /** 重置按钮操作 */
        resetQuery() {
            this.resetForm("queryForm");
            this.handleQuery();
        },
        // 多选框选中数据
        handleSelectionChange(selection) {
            this.ids = selection.map((item) => item.id);
            this.single = selection.length !== 1;
            this.multiple = !selection.length;
        },
        /** 新增按钮操作 */
        handleAdd() {
            this.reset();
            this.open = true;
            this.title = "添加简历档案";
        },
        /** 修改按钮操作 */
        handleUpdate(row) {
            this.reset();
            const id = row.id || this.ids;
            getResume(id).then((response) => {
                this.form = response.data;
                this.open = true;
                this.title = "修改简历档案";
            });
        },
        /** 提交按钮 */
        submitForm() {
            this.$refs["form"].validate((valid) => {
                if (valid) {
                    if (this.form.id != null) {
                        updateResume(this.form).then((response) => {
                            this.$modal.msgSuccess("修改成功");
                            this.open = false;
                            this.getList();
                        });
                    } else {
                        addResume(this.form).then((response) => {
                            this.$modal.msgSuccess("新增成功");
                            this.open = false;
                            this.getList();
                        });
                    }
                }
            });
        },
        /** 删除按钮操作 */
        handleDelete(row) {
            const ids = row.id || this.ids;
            this.$modal
                .confirm("是否确认删除数据项？")
                .then(function () {
                    return delResume(ids);
                })
                .then(() => {
                    this.getList();
                    this.$modal.msgSuccess("删除成功");
                })
                .catch(() => {});
        },
        /** 导出按钮操作 */
        handleExport() {
            this.download(
                "hrm/resume/export",
                {
                    ...this.queryParams,
                },
                `resume_${new Date().getTime()}.xlsx`
            );
        },
    },
};
</script>
